### PATENT APPLICATION:

HP PDNO: 200208134-1

Title: APPLICATION-DRIVEN METHOD AND APPARATUS FOR

LIMITING POWER CONSUMPTION IN A

5 PROCESSOR-CONTROLLED HARDWARE PLATFORM

Inventors: Andrea Acquaviva

Viale Tre Martiri 11

Rovigo 45100

Italy

10 Luca Benini

15

Via Bologna 173 Ferrara 44100

Italy

Tajana S. Rosing

1089 Robin Way

Sunnyvale, California 94087 United States of America

5

10

15

20

25

Title: APPLICATION-DRIVEN METHOD AND APPARATUS

FOR LIMITING POWER CONSUMPTION IN A

PROCESSOR-CONTROLLED HARDWARE PLATFORM

Inventors: Andrea Acquaviva

Luca Benini

Tajana S. Rosing

# BACKGROUND

### Field of the Invention

The present invention relates to an application-driven method and apparatus for limiting the energy consumption associated with the operation of a processor-controlled hardware platform. More specifically, this invention pertains to an operating system having an architecture in which energy consumption is limited through the interaction of appropriately-configured system layers linked by application-program interface ("API") calls.

#### Description of the Prior Art

Battery-operated portable systems, especially those intended for commercial applications such as palmtop computers and PDA's, typically require low cost coupled with fast time to market. Such systems impose tight constraints on energy consumption. Battery capacity has improved slowly (a factor of 2 to 4 over the past 30 years) compared to the drastic increase in computational demands over this same period of time.

Typical portable appliances include a microprocessor-based computer architecture that, coupled with embedded operating systems, simplifies

5

10

15

20

25

application development. The energy efficiency of such systems can typically be improved by design that is aware of not only performance, but also energy consumption of both hardware and software coupled with intelligent utilization of system components at runtime.

The operating system ("OS") is situated to play a major role in the coordination of system power management for processor-based systems such as palmtop computers and PDA's. "Power Management Policy" refers to a set of actions taken by the OS to configure the processor and peripherals for the purpose of reducing system power consumption. Typical actions of an OS in this regard include (1) tuning processor voltage and frequency (2) switching among the different power states available to both the processor and other system devices.

While a few scheduling and resource allocation algorithms aimed at reducing the system power consumption have been attempted in operating systems running on hardware platforms, such techniques have heavily relied upon mathematical modeling techniques of a predictive nature to generate power management policies that employ timed turn-offs and the like. Such techniques are often statistically-based and blind to real time variations that can result in drastically ineffective operational power management policies.

5

10

15

#### SUMMARY OF THE INVENTION

The present invention addresses the preceding and other shortcomings of the prior art by providing, in a first aspect, an improvement to a real time operating system for supporting at least one application, a processor and at least one hardware resource. Such improvement comprises a power manager layer arranged to exchange information with at least one application, the processor and at least one hardware resource to provide real time power management responsive to such information.

In a second aspect, the invention provides a real time power management system for a processor-driven hardware platform for supporting at least one application. Such hardware platform has at least one hardware resource. The processor and the hardware resource are each characterized by a plurality of power states.

An operating system is provided for

controlling the processor and at least one hardware
resource. The operating system includes a power
manager layer arranged to select at least one power
state in response to a real time input from at least
one application.

In a third aspect, the invention provides a method for controlling power consumption in a hardware platform responsive to information from at least one

application. Such hardware platform includes a processor having a plurality of power states and includes at least one hardware resource characterized by a plurality of power states.

5

10

The method of the invention includes the step of organizing the operating system into a kernel, a driver layer, a hardware abstraction layer, and a power manager layer. At least one real time input is applied from an application to the power manager layer. A power management policy is determined in the power manager layer in response to the real time input. The power management policy is communicated from the power manager layer to the processor and at least one hardware resource.

15

20

The preceding and other features of the invention will become further apparent from the detailed description that follows. Such description is accompanied by a set of drawing figures. Numerals of the drawings, corresponding to those of the written description, point to the features of the invention with like numerals referring to like features throughout both the written description and the drawing figures.

25

BRIEF DESCRIPTION OF THE DRAWINGS

Figure 1 is a diagram of the architecture of
a system incorporating an operating system in
accordance with an embodiment of the invention;

5

10

15

20

25

Figure 2 is a block diagram of a power manager layer of an operating system in accordance with an embodiment of the invention;

Figure 3 is a block diagram of a power-aware driver layer of an operating system in accordance with an embodiment of the invention;

Figure 4 is a block diagram of a hardware abstraction layer of an operating system in accordance with an embodiment of the invention;

Figure 5 is a chart illustrating the operation of an integrated power management system for a processor-controlled hardware platform in accordance with an embodiment of the invention; and

Figure 6 is a table of experimental results for illustrating the relative energy savings available to an integrated power management system in accordance with an embodiment of the invention.

#### DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENT

Figure 1 is a block diagram of a processor-controlled hardware platform 10 in accordance with an embodiment of the invention. The platform 10 may comprise a PDA or other battery-operated, possibly hand-held device. It is typical of such devices that control of power consumption is critical.

The platform 10 includes an operating system whose architecture is illustrated within shadow outline 12 in Figure 1. A processor 13 and hardware resources 14 are capable of performing actions that a user may

5

25

activate, either directly or indirectly, from time to time. The actions of the processor 13 and the hardware resources 14 are responsive to one or more applications 16. In the invention, the operating system 12 is arranged to respond to the state and the needs of the applications 16. Such information is communicated by application-program interface (API) calls made to and between the applications and layers of the operating system 12.

10 Referring to the architecture of the operating system 12, it is seen to include four layers that span from hardware to application space. These include, in order, a hardware abstraction layer 18, a kernel 20, a driver layer 22 and a power manager layer 24. The hardware abstraction layer 18 defines architecture and platform specific modules. The kernel 20 consists of schedulers, support for thread synchronization, exception handling, interrupt handling and timers. The driver layer 22 defines the mechanisms for accessing the hardware resources 14.

The processor 13 and at least one hardware resource 14 are of power-aware configurations. That is, each is capable of functioning at a plurality of power states, at least one of such power states being active (operational) and at least one being low power. The power manager layer 24 is arranged to make real time decisions concerning the power states of the processor 13 and the hardware resources 14. The former

5

10

15

20

25

decisions are implemented through API calls to the hardware abstraction layer 13 while the latter are implemented through API calls to the driver layer 22 followed by driver layer 22-to-hardware abstraction layer 18 calls. Such decisions are based upon real time information obtained from the applications 16.

Paths of communication of information within the architecture of the operating system 12 are indicated in Figure 1. As the kernel 20 and its functions are conventional and not relevant to the power management functions of the invention, paths of communication between it and the other elements of the operating system 12 are indicated by dashed lines. Solid lines 26, 28, 30 and 32 indicate communication, via API calls, between the power manager 24 and the hardware abstraction layer 18, the power manager layer 24 and the driver layer 22, the applications 16 and the power manager layer 24 and the hardware abstraction layer 18 and the driver layer 22. Each of the applications 16, the hardware abstraction layer 18, the driver layer 22 and the power manager layer 24 is configured to send, receive and act upon an appropriate API call.

The present invention integrates the power manager layer 24 into the operating system 12. Figure 2 is a functional diagram of the power manager layer 24. It includes a number of operational modes including processor power state selection 34 and

5

10

15

20

25

30

hardware resource power state selection 38. Ancillary devices are associated with the various modes of the power manager 24. Processor power state selection 34 relies upon an application running list 40 and an application profiles database 42 while hardware resource power state selection 38 relies upon a resource table 44. The application running list 40, as the name implies, informs the power manager layer 24 of which, if any, applications are currently running on the platform 10. It will be seen below that such knowledge is essential to determining when the poweraware elements of the system are to be returned to low power states. The application profiles database 42 receives and stores the relationship between processor utilization and processor clock frequency for a particular application(s). The resource table 44 comprises a list of the hardware resources in use at any given time.

The power manager layer 24 receives the status and operational requirements of each application capable of running on the platform 10 and determines the appropriate power-saving adjustments to the system hardware in response. Such adjustments include processor and hardware power state selections. By centralizing such decisions in the power manager layer 24 of the operating system 12 that will be seen to be responsive in real time to the application(s) of the hardware platform 10, one is able to implement an integrated power management policy that will be seen,

5

10

15

20

25

below, to yield significant energy savings and, accordingly, greatly enhance the utility of a hand-held battery-operated device.

The power management decisions made within the power manager layer 24 are caused to be implemented through instructions provided to dedicated configuration controls located within the hardware abstraction layer 18 and power-aware driver layer 22. API calls to the power aware driver layer 22 (API<sub>PM/PAD</sub>) transmit power management decisions that pertain to the states of hardware resources. Such calls result in subsequent calls (API<sub>PAD/HAL</sub>) advising the hardware abstraction layer 18 of actions (resource power state) to be taken with regard to the relevant hardware It will be seen that the system of API resources. calls and power management policy responsive to application needs and status permits usage of low power hardware resource states without incurring a resource start-up penalty.

Power management policy pertaining to the operation of the processor 13 (processor mode selection) is transmitted directly to the hardware abstraction layer 18 for implementation by means of API<sub>PM/HAL</sub> calls. The hardware abstraction layer 18 is of the "low power" or "power-aware" type insofar as it is configured to provide the commands required to cause the processor 13 and the hardware resources 14 to switch from power state to power state upon receipt of

### <u>HP PD 200208134-1</u>

5

10

15

20

25

appropriate API calls from the power manager layer 24 and from the driver layer 22 respectively.

Figure 3 is a block diagram of the driver layer 22 of the operating system 12. The driver layer 22 receives calls (API<sub>PM/PAD</sub>) from the power manager layer 24 transmitting power management policy decisions pertaining to changes in the power states of hardware The status of hardware resources 14 are resources 14. confirmed and reported to the power manager layer 24 by means of API<sub>PAD/PM</sub> calls. Resource power state instructions are transmitted to the hardware abstraction layer 18 for execution by means of API PAD/HAL calls. As in the case of the hardware abstraction layer 18, the driver layer 22 is configured for poweraware in that it is able to process an API call received from the power manager layer 24 containing a real time power management policy decision to change the power state of a hardware resource 14 and to transmit an appropriate API call to the low power hardware abstraction layer 18 to cause such layer to generate a command in response that will cause the power state of the hardware resource 14 to be changed accordingly.

Figure 4 is a block diagram of the hardware abstraction layer 18 of the operating system 12. The hardware abstraction layer 18 may be thought of as comprising both a software side 46 and a hardware side 48. On the software side 46, the layer 18 is arranged

to receive calls reflecting power management policy relating both to the processor 13 and to the hardware resources 14. On the hardware side 48, a processor configuration control 50 and a plurality of resource configuration controls 52 are provided for generating hardware commands in the form of electrical signals, transmitted via conductors 54 and 56 respectively, that result in execution of the power management policy directed by the power manager layer 24.

10

15

5

The software side 46 of the low-power hardware abstraction layer 18 receives, as inputs, calls API<sub>PM/HAL</sub> that contain processor power state directions from the power manager layer 24 and confirms processor status to the power manager 24 by means of calls API<sub>HAL/PM</sub>. Directions pertaining to the operation of the hardware resources 14 of the platform 10 are received from the driver layer 22 by API<sub>PAD/HAL</sub> calls while the states of hardware resources 14, are reported back to the driver layer 22 by means of API<sub>HAL/PAD</sub> calls.

20

25

As can be seen, API calls communicate information among the layers of the operating system 12. It will be shown below that such calls also provide a communication link between the applications 16 and the operating system 12 that enables application-driven power management of the processor-driven hardware platform 10.

5

10

15

25

A format for embedded API calls for affecting the communication employed in an operating system 12 in accordance with the invention is as follows:

- A. Communication Between Application and Power Manager Layer (API calls embedded in application)
- i) pm\_application\_start(app\_handle,
  app\_name):
  (Application 16 informing power manager layer 24 that
  it is starting);
- ii) pm\_application\_end(app\_handle, app\_name):
   (Application 16 informing power manager layer 24 that
   it has ended);
  - iii) pm\_res\_alloc(app\_handle, res\_handle):
    (After application has begun, power manager layer is
    notified that application requires a hardware resource
    14);
  - iv) pm\_res\_dealloc(app\_handle, res\_handle):
    (Application no longer requires the particular hardware
    resource 14); and
- v) pm\_app\_profile(app\_handle): (Application informs the power manager layer of its power and performance characteristics).
  - B. Communication between Power Manager Layer and Driver Layer (API<sub>PM/PAD</sub>)
  - i) pm\_res\_init(res\_data): (Power manager
    layer tells driver layer to turn on and initialize a
    hardware resource 14);
  - ii) pm\_res\_power\_state\_set (res\_data): (Power
    manager layer sets the power state of the hardware

5

10

15

20

- C. Communication between Power Manager Layer and Hardware Abstraction Layer (API<sub>PM/HAL</sub>)
  - i) pm\_change\_speed(new\_speed): (Power manager layer tells hardware abstraction layer to adjust frequency of processor clock);
- ii) pm\_init(data): (Power manager layer tells
  hardware abstraction layer to transition processor 13
  to active power state); and
  - iii) pm\_power\_state\_set(data): (Power manager layer tells hardware abstraction layer to transition processor 13 to a specific power state).
  - D. Communication Between Driver Layer and Hardware
    Abstraction Layer
  - i) pm\_power\_state\_set: (Driver layer informs
    hardware abstraction layer to set a hardware resource
    14 power state);
  - ii) pm\_power\_state\_get: (Driver layer 22 asks
    hardware abstraction layer 18 about power state of a
    hardware resource 14).
- Figure 5 is a chart illustrating the

  25 operation of an integrated power management system for a processor-controlled hardware platform in accordance with an embodiment of the invention. The sequence of

5

10

15

20

25

operations has been broken into eleven steps S-1 through S-11 corresponding to rows of the chart. Columns indicate (from left) events initiated outside the operating system 12, including real time API calls from an application to the power manager layer 24, actions of and API calls from the power manager layer 24, actions of API calls from the driver layer 22 and actions of the hardware abstraction layer 18 respectively. Communications between applications and the power manager layer 24 are indicated by "API to Power Manager Call" while communications within the layers of the operating system 12 are indicated by API call notation as described with reference to the The substantive content of each API preceding figures. call is indicated in parentheses beneath each (underlined) call.

Referring to steps S-1 through S-11 whereby power management is accomplished in accordance with an embodiment of the invention, the entire system of the hardware platform is in an idle power state at step S-1. The multiple power states of power-aware devices, including processors and hardware resources, may be divided into two classes. The first class of power states is denoted "active" or "operational". Such class of power states of a processor or hardware resource is characterized by two factors. The first of such factors is the power consumption of the device and the other factor is its processing speed.

5

10

15

20

25

The second class of power states of a poweraware processor or hardware resource is denoted "low Examples of varieties of low power states include, for example "sleep", "doze" and "off". low power states of power-aware processors and hardware devices are characterized by another set of factors, namely, (1) power consumption (as before) and (2) time delay required for reentry into an active or Such power-aware characteristics of operational state. the processor and the hardware resources are transmitted to the power manager layer 24 from the hardware abstraction layer 18 whereby they are taken into account by the power manager layer 24 in formulating a real time power management policy as described below.

A user takes some action triggering an electrical or mechanical signal that is recognized by the hardware platform. This activates the system at step S-2, causing the processor 13 to transition to an active state and generating in API calls from the driver layer 22 and the hardware abstraction layer 18 that inform the power manager layer 24 of the power—aware characteristics of the available processor 13 and hardware resources 14. Thus, after step S-2, the power manager layer 24 possesses the necessary information for taking the power—aware characteristics of the various devices into account in making subsequent power management decisions.

5

10

15

20

25

The application, activated by the user at step S-2, begins to run at step S-3. The application informs the power manager layer that it has begun by an API call at step S-4 and, in response, the power manager layer 24 updates the application running list 40 accordingly.

At step S-5, an API call is sent from the application to the power manager layer 24 informing it in real time of a computing need that has arisen. might be dictated, for example, by the requirement of an MP3 decorder application to receive data from a WAVELAN card at a sufficiently high rate to deliver a real time audio output to the user through the speakers of the hardware platform. When such a call is received at the power manager layer 24, a decision concerning the appropriate speed of the processor 13 is made with reference to the application profile that indicates the relevant tradeoff of application data rate and processor speed stored in the application profiles 42. The processor speed is then transmitted at step S-5 by API call to the hardware abstraction layer 18 and the speed of the processor 13 set by an appropriate corresponding command from the hardware abstraction layer 18 to the processor 13.

The application may then inform the power manager layer 24 of a hardware resource need required for application execution at step S-6. Such hardware resource need is communicated by API call embedded in

5

10

15

20

25

the application to the power manager layer 24 resulting in a call from the power manager layer 24 to the driver This causes an API call to be made from the layer 22. driver layer 22 to the hardware abstraction layer 18 that results in the generation of appropriate commands for activating the desired hardware resource 14 (assuming that such hardware resource 14 is at a low power state at the time and has not already been activated for use by another application). transition of the desired hardware resource from a low power state to an active state is reported to the power manager layer 24 through API calls originating with the hardware abstraction layer 18 and, in response, the power manager layer 24 causes the resource table 44 to be updated accordingly. Such transition may occur concurrently with the initialization sequence of the application whereby a user would be unable to perceive any delay in transitioning the hardware resource to an active state. The application is running with the appropriate hardware resource engaged at step S-7.

The application then notifies the power manager layer 24 that the hardware resource 14 is no longer needed by API call at step S-8. This results in (1) the power manager layer 24 notifying the driver layer 22 to initiate turn off of such hardware resource 14 unless it is currently required for another application and, assuming that it is not required for another application at this time ad (2) the driver layer 22 notifying the hardware abstraction layer 18 by

5

10

15

20

25

API call to return the hardware resource 14 to a low power state. Once the hardware abstraction layer 18 has generated the appropriate commands to return the hardware resource 14 to a low power state, this information is relayed through API calls to the power manager layer 24 where the resource table 44 is correspondingly updated.

At step S-9, the application notifies the power manager layer 24 by API call that the application is complete. The power manager layer 24 denotes this in the application running list 40 and re-calculates processor 13 speed based upon the deletion of the performance requirement occasioned by the (former) active or operational state of such application. The re-calculated processor 13 speed is transmitted to the hardware abstraction layer 18 by API call where corresponding commands are generated for resetting the speed of the processor 13.

At step S-10, the power manager layer 24, upon receiving notification from the last of the applications indicated by the application running list 40 to have been running that such application is now complete, makes an API call to the hardware abstraction layer 18 telling the layer 18 to transition the processor 13 to a low power state and, should the resource table 44 indicate that any hardware resource is active, notifies by driver layer 22 by API call to transition such hardware resource(s) to low power

5

10

15

state. The hardware platform thereby returns to low power state at step S-11.

As can be seen from the above-described process, power-saving decisions are made at the power manager layer 24. The power management policy is set in this single layer of the operating system 12. power management decision is made by the power manager layer 24 upon receipt and consideration of an action pertaining to an application. Thus, power management policy is application and event driven in the present invention in contrast to systems that rely in whole or in part upon timed turn-offs and the like based upon resource and processor modeling rather than input from applications. Finally, it can be seen that the power aware driver layer 22 is arranged and capable of providing power-aware directions to appropriatelyconfigured hardware resources 14 and the hardware abstraction layer 18 is capable of causing power-aware instructions to be executed by the processor 13.

Power saving features of the invention that are evident from a review of Figure 5 include (1) the ability to "call up" a hardware resource only when needed rather than initialize it when the system is turned on, (2) ability to mask the delay of transitioning a hardware resource to an active state by starting the transition during the initialization sequence of the application, (3) continual recalculation of processor speed in accordance with the

platform.

needs of currently-running applications, and (4) transitioning of both hardware resources 14 and the processor 13 to low power states as soon as possible without the expenditure of idling energy.

Experimental results confirm the power 5 savings that may be realized in a processor-controlled hardware platform configured and operating in accordance with the invention. Figure 6 is a table of experimental results for illustrating the relative energy savings available to an integrated power 10 management system. The data presented in the figure are based upon the implementation of the invention on a PDA hardware platform that is commercially available from the Hewlett-Packard Company of Palo Alto, California under the SMART BADGE IV trademark. 15 hardware resources of the processor-controlled SMART BADGE IV platform comprise (in addition to a processor), a wireless local area network card (WAVELAN), memory and speakers while an MP3 audio decoder application is run on the platform. 20 audio decoder application receives frames through a wireless link, decodes them and plays the resultant audio out on the speakers. The WAVELAN power-aware driver generates  $API_{PAD/HAL}$  calls for causing the wireless link and processor frequency/voltage to be controlled 25 in response to the power management policy. Power was measured by monitoring the current absorption of the

The MP3

5

10

15

20

25

Comparisons in the table of Figure 6 are made for four different cases:

- i) NO POLICY: Application runs at full speed with hardware resources always "ON";
- ii) CPU SHUT-DOWN: Application employs only
  processor shut-down (hardware resource shut-down not
  available);
- iii) CPU & DEVICES SHUT-DOWN: Both processor
  and hardware resource shut-down utilized; and
- iv) CPU & DEVICES SHUT-DOWN AND CLOCK
  SCALING: Processor clock scaling, processor shut-down
  and hardware resource shut-down available.

The processor clock scaling (case "iv") policy utilized within the power manager layer 24 of the experimental system calculates processor clock frequency in accordance with the header of each MP3 The details of such policy are disclosed in an article of A. Acquaviva, L. Benini and B. Ricco, "Software Controlled Processor Speed Setting for Low-Power Streaming Multimedia", IEEE Transactions of CAD (November 2001) at pages 1283 through 1292. Of course, the invention is not limited to such policy. Rather numerous other power-aware policies may be adopted for regulating the adjustable frequency of the processor The choice of an appropriate power-aware policy for regulating processor clock frequency may rely upon a number of factors including application, hardware resource and processor characteristics.

5

10

15

20

25

The operation of the above-described hardware platform is as follows. The processor transitions into running state as soon as the MP3 decoder application begins execution. MP3 application informs the power manager of its resource needs through an API call. power manager responds by making APIPM/PAD calls to the power-aware WAVELAN device drivers. Next, the application informs the processor of its processing The power manager layer needs via APIPAD/HAL call. responds by making an API<sub>PM/HAL</sub> call to set processor frequency and voltage appropriately. When a hardware resource is no longer needed, the power manager layer is informed by the MP3 decoder via an API call and responds, via an APIPM/PAD call followed by an APIPAD/HAL call, to cause such hardware resource to be turned OFF (i.e. transitioned to a lower power state). MP3 decoder has completed the decoding process, it informs the power manager layer by API call. The power manager layer first initiates shutoff of all hardware resources through  $API_{PM/PAD}$  calls. This is followed by an API<sub>PM/HAL</sub> call to initiate the processor shut-down sequence.

Referring to the table of Figure 6, it is seen that the combination of processor clock scaling, device and processor shut-down more than double system power efficiency. About 50.7 per cent of power savings occur when only processor and device shut-down are utilized. In addition to saving power, a performance improvement was noted resulting from the fact that the

5

10

15

20

25

CPU does not process useless broadcast packets coming from the network since the WAVELAN card is shut down as soon as the incoming frame buffer is full.

Additional 8 per cent savings is obtained by employing processor clock scaling. The magnitude of the savings is limited, first, by the computationally-intensive nature of the MP3 decoder which limits the ability to reduce processor clock speed. Secondly, as only clock frequency scaling was available on the SMART BADGE IV hardware platform employed, the potentially much greater power reductions available, through known power management policies, when scaling down processor voltage at the same time that processor clock frequency is slowed down, could not be utilized in the power management policy of the power manager layer. Similar results have been obtained on a hardware platform in accordance with the invention employing multi-tasking.

Thus it is seen that the present invention provides both apparatus and a method for limiting power consumption in a processor-controlled hardware platform. By utilizing the teachings of the invention, one may realize substantial reductions in power consumption. Such conservation of power is especially critical in the case of hand-held, battery-powered devices.

While this invention has been disclosed with reference to its presently-preferred embodiment, it is

not limited thereto. Rather, the invention is limited only insofar as it is described by the following set of drawing figures and includes within its scope all equivalents thereof.